package com.sisgesbyte.dao.proyeccion;

import java.util.List;

import javax.ejb.Stateless;
import javax.inject.Inject;
import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;
import javax.persistence.Query;

import com.sisgesbyte.dao.beanDao.FiltrosSQLBean;
import com.sisgesbyte.dao.beanDao.ProyMontoPeriodoRequest;
import com.sisgesbyte.dao.utilDao.CreaFiltroSqlString;
import com.sisgesbyte.data.entity.comun.GenericEntity;
import com.sisgesbyte.data.entity.proyeccion.BandaProyeccionEntity;
import com.sisgesbyte.data.entity.proyeccion.ProyeccionPeriodoEntity;
import com.sisgesbyte.data.util.AbstractFacade;

@Stateless
public class MantProyeccionPeriodoDaoImpl  extends AbstractFacade<BandaProyeccionEntity> implements MantProyeccionPeriodoDao {

	@Inject
	private CreaFiltroSqlString creaFiltroSqlString;
	
	@PersistenceContext(unitName = "SigesSiscompPU")
	private EntityManager em;

	@Override
	protected EntityManager getEntityManager() {
		return em;
	}
	
	public MantProyeccionPeriodoDaoImpl(){
		super(BandaProyeccionEntity.class);
	}
	
	@Override
	public List<ProyeccionPeriodoEntity> listaProyeccionPorPeriodo(FiltrosSQLBean cadenaFiltros) {
		StringBuilder jpql = new StringBuilder();
		jpql.append("SELECT pp.id, pp.periodo_id,p.descripcion periodo, pp.monto_proyectado, pp.codigo_banda ");
		jpql.append("FROM proyeccion.proyeccion_periodo pp ");
		jpql.append("inner join ventas.periodo p on pp.periodo_id=p.id ");
		// concatenamos el filtro
		if (cadenaFiltros != null) {
			StringBuilder filtro = new StringBuilder();
			filtro.append(creaFiltroSqlString.concatenar(cadenaFiltros));
			jpql.append(filtro.toString());
		}
		Query query = em.createNativeQuery(jpql.toString(), ProyeccionPeriodoEntity.class);
		if (cadenaFiltros != null && cadenaFiltros.getListaValores() != null
				&& cadenaFiltros.getListaValores().size() > 0) {
			int num = 0;
			for (Object valor : cadenaFiltros.getListaValores()) {
				query.setParameter(++num, valor);
			}
		}
		List<ProyeccionPeriodoEntity> ls = query.getResultList();

		return ls;
	}

	@Override
	public GenericEntity guardarProyeccionMontoPeriodo(
			ProyMontoPeriodoRequest request) {
		StringBuilder jpql = new StringBuilder();
		jpql.append("SELECT * from proyeccion.sp_registrar_proyeccion_monto_periodo( :in_periodo_id,:in_monto_proyectado)");
		Query query = em.createNativeQuery(jpql.toString(), GenericEntity.class);
		query.setParameter("in_periodo_id", request.getIdPeriodo());
		query.setParameter("in_monto_proyectado", request.getMontoProyectado());
		
		return (GenericEntity) query.getSingleResult();
	}

	@Override
	public GenericEntity actualizarProyeccionMontoPeriodo(
			ProyMontoPeriodoRequest request) {
		StringBuilder jpql = new StringBuilder();
		jpql.append("SELECT * from proyeccion.sp_actualizar_proyeccion_monto_periodo(:in_periodo_id, :in_monto_proyectado) ");
		Query query = em.createNativeQuery(jpql.toString(), GenericEntity.class);
		query.setParameter("in_periodo_id", request.getIdPeriodo());
		query.setParameter("in_monto_proyectado", request.getMontoProyectado());
		
		return (GenericEntity) query.getSingleResult();
	}

	@Override
	public GenericEntity eliminarProyeccionMontoPeriodo(int codProyeccion) {
		StringBuilder jpql = new StringBuilder();
		jpql.append("SELECT * from proyeccion.sp_eliminar_proyeccion_monto_periodo(:in_id)");
		Query query = em.createNativeQuery(jpql.toString(), GenericEntity.class);
		query.setParameter("in_id", codProyeccion);

		return (GenericEntity) query.getSingleResult();
	}

	@Override
	public GenericEntity actualizarBandaProyeccionMontoPeriodo(
			ProyMontoPeriodoRequest request) {
		StringBuilder jpql = new StringBuilder();
		jpql.append("SELECT * from proyeccion.sp_actualizar_banda_proyeccion_periodo(:in_id ,:in_codigo_banda) ");
		Query query = em.createNativeQuery(jpql.toString(), GenericEntity.class);
		query.setParameter("in_id", request.getId());
		query.setParameter("in_codigo_banda", request.getCodigoBanda());
		
		return (GenericEntity) query.getSingleResult();
	}

}
